image-20191015211722056

image-20191015211818980


代码实现

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
import java.util.ArrayList;
import java.util.Arrays;

public class Graph {

//存储顶点集合
private ArrayList<String> vertexList;
//存储图对应的邻接矩阵
private int[][] edges;
//表示边的数目
private int numOfEdges;
//定义给数组 boolean[], 记录某个结点是否被访问
private boolean[] isVisited;

public static void main(String[] args) {
int n = 8;
String Vertexs[] = {"A", "B", "C", "D", "E"};
//创建图对象
Graph graph = new Graph(n);
//循环的添加顶点
for (String vertex : Vertexs) {
graph.insertVertex(vertex);
}
graph.insertEdge(0, 1, 1);
graph.insertEdge(0, 2, 1);
graph.insertEdge(1, 2, 1);
graph.insertEdge(1, 2, 1);
graph.insertEdge(1, 3, 1);
graph.insertEdge(1, 4, 1);
//显示一把邻结矩阵
graph.showGraph();

}

public Graph(int n) {
//初始化矩阵和 vertexList
edges = new int[n][n];
vertexList = new ArrayList<>(n);
numOfEdges = 0;
}

//插入结点
public void insertVertex(String vertex) {
vertexList.add(vertex);
}

//添加边* *
// @param v1 表示点的下标即使第几个顶点 "A"-"B" "A"->0 "B"->1
// * @param v2 第二个顶点对应的下标
// * @param weight 表示
public void insertEdge(int v1, int v2, int weight) {
edges[v1][v2] = weight;
edges[v2][v1] = weight;
numOfEdges++;
}

//显示图对应的矩阵
public void showGraph() {
for (int[] link : edges) {
System.out.println(Arrays.toString(link));
}
}
}

TOList BFS DFS